// ==UserScript== // @name Video Audio Compressor // @namespace https://github.com/tjxwork // @version 0.0.1 // @description 视频音量压缩器,防止耳聋,避免响度战争,懒得写UI了,直接改脚本文件里面的数值吧。 // @author tjxwork // @license CC-BY-NC-SA // @icon  // @match https://*.bilibili.com/* // @match https://*.youtube.com/* // @grant GM_registerMenuCommand // @grant GM_setValue // @grant GM_getValue // ==/UserScript== "use strict"; function AudioCompressor() { // 音频元素 const audioElement = document.querySelector("video"); // 设置音频上下文 let audioContext = new AudioContext(); // 创建 音频来源节点 MediaElementAudioSourceNode,将 音频元素 输入其中 const source = new MediaElementAudioSourceNode(audioContext, { mediaElement: audioElement, }); // 创建压缩器节点 const compressor = new DynamicsCompressorNode(audioContext, { //----------修改数值处---------- // 阈值(dB) threshold: -24, // 拐点过渡(dB) knee: 5, // 压缩比例 ratio: 18, // 启动时间(S) attack: 0, // 释放时间(S) release: 0.25, //----------修改数值处---------- }); // 音频来源节点 -x-> 音频目标 //source.disconnect(audioContext.destination); // 音频来源节点 -> 压缩器节点 -> 音频目标 source.connect(compressor); compressor.connect(audioContext.destination); } // 页面加载完成后运行脚本 window.addEventListener("load", AudioCompressor);